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MEANING-BASED ADVERTISING AND DOCUMENT RELEVANCE 

DETERMINATION 

1 # Field of the Invention 

The invention relates generally information organization and 
5 retrieval. More specifically, the invention relates to 
advertising and document relevance determination. 

2. Background 

This application is a continuation-in-part of U.S. Patent 
Application Serial Number 09/431,760 filed on November 1, 1999 
10 entitled * Meaning-Based Information Organization and Retrieval/' 

The Internet, which is a global network of interconnected 
networks and computers, commonly makes available a wide variety 
of information through a vehicle known as the World Wide Web 
(WWW) . Currently, hundreds of millions of "web sites/' that 
15 house and format such information in documents called web pages 
are available to users of the Internet. Since the content of 
such pages is ungoverned, unregulated and largely unorganized 
between one site and the next, finding certain desired 
information is made difficult. 

20 To aid users in finding sites or pages having information 

they desire, search engines were developed. Search engines and 
directories attempt to index pages and/or sites so that users can 
find particular information. Typically, search engines are 
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initiated by prompting a user to type in one or more keywords of 
their choosing along with connectors (such as "and") and 
delimiters. The search engine matches the keywords with 
documents or categories in an index that contain those keywords 
5 or are indexed by those keywords and returns results (either 

categories or documents or both) to the user in the form of URLs 
(Uniform Resource Locators) . One predominant web search engine 
receives submissions of sites and manually assigns them to 
categories within their directory. When the user types in a 

10 keyword, a literal sub-string match of that keyword with either 
the description of the site in their index or the name of the 
category occurs. The results of this sub-string search will 
contain some sites of interest, but in addition, may contain many 
sites that are not relevant or on point. Though one may refine 

15 the search with yet more keywords, the same sub-string match will 
be employed, but to the result set just obtained. Almost all 
search engines attempt to index sites and documents and leave it 
to the user to formulate an appropriate query, and then to 
eliminate undesired search results themselves. Recently other 

20 search engines using natural language queries have been developed 
but these also often result in many undesired responses. 

The quality of the results obtained varies, but by doing 
essentially sub- string matches or category browsing, the engines 
are unable to properly discern what the user actually intends or 
25 means when a particular keyword is entered. Thus, the response 
to search terms entered is a list of documents/sites that may 
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bear little relation to the intended meaning/usage of the term(s) 
entered. 

One corollary response to search terms input into search 
engine is the retrieval and display of advertising icons often 
5 referred to as "banner ads/' One ad-buying model for companies 
and web sites desiring to advertise on a search engine is to 
purchase one or more search terms. When the search term(s) are 
input by a user of the search engine, the corresponding banner ad 
is displayed. Again, because of the limitation of most search 

10 engines, the advertiser must purchase several search terms to 
cover a given concept or meaning that may have multiple 
equivalent terms associated with them. For instance, a computer 
manufacturer may have to buy "computer/' "PC/' and "desktop" if 
they desire to have an ad for computers appear. If the 

15 advertiser cannot afford the increase in cost certain equivalent 
expressions may be entirely missed by the ad campaign. One other 
factor with banner ads is that related terms or expressions may 
be completely ignored. For instance, the term "hardware" is not 
equivalent but related to "computer" and may be a related concept 

20 the advertiser desires to capture but cannot unless explicitly 
purchased . 

The responses to a given search term are often based upon 
the manner in which documents or pointers to documents are 
indexed in a directory. Internet search engines often index 
25 documents and pointers to those documents based upon one or more 
keywords, which may be embedded within the document, and/or 
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automatically determined by analyzing the document or input 
manually by a user or reviewer desiring to have the document 
indexed. Some of these methods of indexing rely on the precision 
of the terms used and not concepts or meanings. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The objects, features and advantages of the method and 
apparatus for the present invention will be apparent from the 
following description in which: 

5 Figure 1 is a flow diagram of the operation of a meaning- 

based search engine. 

Figure 2 illustrates a portion of a relationship based 
lexicon employed in one or more embodiments of the invention. 

Figure 3 illustrates the concept of bond strength and 
10 semantic distance employed in one or more embodiments of the 
invention. 

Figure 4 illustrates the application of synsets to 
categories in a subject directory tree. 

Figure 5 is a system diagram of one embodiment of the 
15 invention. 

Figure 6 is a flowchart of meaning-based advertising 
according to one or more embodiments of the invention. 

Figure 7 illustrates advertisements within a semantic sub- 
space . 

20 Figure 8 is a flowchart of keyword generation by semantic 

filtering. 
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Figure 9 is a graph of meaning-based advertising pricing 
according to another embodiment of the invention. 



0003.P001CIP 



6 



EMS# EK100514799US 



DETAILED DESCRIPTION 

Referring to the figures, exemplary embodiments of the 
invention will now be described. The exemplary embodiments are 
provided to illustrate aspects of the invention and should not be 
5 construed as limiting the scope of the invention. The exemplary 
embodiments are primarily described with reference to block 
diagrams or flowcharts. As to the flowcharts, each block within 
the flowcharts represents both a method step and an apparatus 
element for performing the method step. Depending upon the 
10 implementation, the corresponding apparatus element may be 
configured in hardware, software, firmware or combinations 
thereof. 

The searching paradigm presented herein relies on an 
unconventional approach to information retrieval; namely, the 

15 idea of a "meaning-based" search. Instead of simply indexing 

words that appear in target documents, and allowing users to find 
desired word instances within documents or an index, searches are 
instead conducted within the realm of " semantic space" , allowing 
users to locate information that is "close in meaning" to the 

20 concepts they are interested in. 

A search engine and searching paradigm so implemented 
enables Web users to easily locate subject categories within a 
large subject directory, such as Netscape's Open Directory (a 
25 product of Netscape Communications Corporation) by a convenient 
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and meaningful manner. A "target document" refers to a single 
subject page within such a directory. Such a subject directory 
is arranged in a roughly hierarchical fashion and consists of 
many unique topics. By allowing users to refine their searches 
5 to specific meanings of words, the invention in its various 
embodiments enables users to quickly filter out undesired 
responses, and therefore achieve more precise and more relevant 
search results. For example, the user would be able to filter 
out results relating to the concept of "Bulls" as a basketball 

10 team, because they are only interested in the concept of "Bulls" 
as a kind of cattle. Because searches conducted using search 
engines implemented according to the invention result in 
presenting conceptual areas "near" to a particular meaning, the 
user is also presented with categories that are likely to be of 

15 interest, yet might have been missed by a traditional search 

approach. An example would be a result of "Cows" to a search on 
"Bulls", which would come up as a result because the concepts are 
deemed "near" to each other in semantic space. 

Figure 1 is a flow diagram of one or more embodiments of the 
20 invention. 

The flow diagram in Figure 1 for implementing meaning-based 
information organization and retrieval system may be summarized 
25 as follows: 
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Pre-Processizig/Organization 

1. Define a * semantic space" by creating an interconnected 
lexicon of meanings, 

2. Determine the * semantic distance" between meanings in 
5 semantic space that describes how close, conceptually, one 

meaning is to another. 

3. Designate a " location" in semantic space for each target 

document . 

4. Pre-calculate "scores" for each * target document" for each 
10 relevant input meaning, based on nearness in semantic space 

obtained by measuring semantic distance. 
Retrieval 

1. Implement a search engine that converts an input string 
into a set of probable desired meanings, then locates targets 

15 based mainly on pre-calculated scores. 

2. Create a user- interface to the engine that allows users to 
easily make "initial" and "refined" searches, and that presents 
results to users in a logical and orderly fashion. 

Referring to Figure 1: 
20 Block 110 

In the pre-processing or organization stage, the first step 
is develop/update a useful meaning-based lexicon (block 110) . A 
"lexicon" is a network of interconnected meanings; it describes 
25 the "semantic space" that is employed by the search engine. One 
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such lexicon already in existence consists of thousands of 
meanings, or "synsets", which are connected to one another 
through two key relationships: "kind of" and "part of" . For 
example, the concept of "table" is connected to the concept of 
5 "furniture" through a "kind of" connection. Thus, "table" is a 
kind of "furniture". Similarly, "California" is a part of 
"United States" . 

From this basis, the lexicon can be updated and expanded to 
include new meanings or update connections for meanings already 

10 present. New meanings can be updated mainly to reflect the 

importance in everyday culture of a large number of proper nouns, 
which are not available in many lexicons such as the names of 
companies, people, towns, etc. In addition, new meanings may 
have to be developed within the lexicon in order to cover subject 

15 areas of common interest with greater specificity. For example, 
whereas an existing lexicon might define the idea of a 
"programming language", it may be useful to expand this concept 
within the lexicon to designate the many hundreds of specific 
programming languages that may exist as "kind of" children to 

20 this meaning. 

Additionally, an innovative type of relationship between 
meanings has been developed as a corollary to the invention, in 
order to convey information that is not treated in lexicons. This 
25 relationship, called a "bind", describes one meaning's closeness 
to another meaning in people's common understanding. For 



0003.P001CIP 



EMS# EK100514799US 




example, " skier" and " skiing" are not closely related concepts in 
existing lexicons. The former is a kind of "athlete", ultimately 
a kind of "human being"; and thus would reside within the 
"entity" or "living thing" tree. The latter is a kind of 

5 " sport", ultimately a kind of "activity"; it is in the "actions" 
tree. Though the subjects are closely related in everyday usage, 
they may be in widely separated locations within the lexicon's 
network of meanings. To remedy this, a "bind" has been made 
between the two meanings, to reflect their close proximity in 

10 semantic space (when you think of one concept, you tend to think 
of the other) . This new type of bonding between meanings is 
essential for creating a "semantic space" that will yield useful 
search results. 

An extension to this "bind" connection is the concept of 

15 varying "bond strengths" between meanings. A value can be 
assigned to a connection from one meaning to another that 
signifies how strongly the second meaning relates to the first. 
These connection strengths are dependent on the direction of the 
bond, so that, for example, "skier" might imply a strong 

20 connection to "skiing", whereas "skiing" need not imply "skier" 
to the same degree. 

One other enhancement is the addition of a "commonness" 
value to each meaning, which reflects a combination of "how often 
does this concept arise in everyday usage" and "how specific a 

25 concept is this"? This value allows both more accurate 
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interpretation of input terms passed to the search engine ("what 
is more likely to be meant by this?"), as well as improved 
ranking of search results, showing users the results that they 
are more likely to be interested in first (the more specific 
terms are likely to be more important to the user) . 

Meanings within the lexicon may also be flagged in several new 
ways : 

• Meanings that signify geographical places are marked as 

" locations" . This allows special calculations to come into 
play in the search engine that are unique to these meanings. 

• Meanings that are "offensive" are marked, indicating that the 
general public may find these meanings to be distasteful or 
vulgar in some way. This flag allows us to give users the 
option to filter search results that they may find offensive. 

• Meanings that signify specific "instances" of things are 
marked. For example, "computer company" is a generic kind of 
concept, but "Microsoft" describes a unique entity. Knowing 
when "kind of" children of a meaning are "instances" allows 
the semantic distance calculations to more accurately estimate 
the precision of a parent meaning (this is described in more 
detail later) . 

• The "currentness" of meanings may be noted. Meanings marked as 
"current" are those that are in some way timely; values 
surrounding them are more likely to vary over time than other 
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concepts. For example, the word "Monica" might currently imply 
the meaning " Monica Lewinsky" to a greater degree today than 
it might will a year from now. By marking meanings that are 
uniquely likely to change within the near future, the Lexicon 
5 may be more easily kept up to date. 

• Meanings may be marked as "pseudosynsets" . This term describes 
meanings that are either not in common usage because they are 
highly specific or technical, or that exist within the Lexicon 
purely for the purpose of forming a parent category for a 

10 group of child meanings. An example of the former might be the 
Latin terms that describe phylum, class, or species within the 
biological taxonomy. An example of the latter would be the 
concept of "field sports", which exists mainly for the purpose 
of grouping similar specific sports together cleanly in the 

15 Lexicon, rather than because it in itself is actually an oft 

used meaning in common usage. By marking "pseudosynsets" , more 
accurate values for semantic distance may be calculated (this 
is described in more detail later) . 

Block 115 

20 

Each subject, or node, within the directory is given a 
"location" within the semantic space that is established by the 
Lexicon. Before a search engine can find anything within this 
space, targets to retrieve must be placed there. The process is 
25 envisioned to be a manual one; editors examine each directory 
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subject node, and decide upon the "meaning" of the subject. 

However, this process may also be automated. 

To specify a node's location in semantic space, one or more 

individual meanings from the Lexicon are * attached" to the node. 
5 These meanings may be grouped together into "synset groups", each 

of which, in a sense, describes the node's position within a 

different dimension of semantic space. 

For example, a node within the directory that is about 

"Piano Players" would be assigned the meaning piano player. A 
10 node about "Piano Players in Australia" would be assigned two 

meanings, piano player and Australia. The two concepts represent 

two distinct "synset groups" on the node, as each establishes a 

location for the node within a different " dimension" of meaning. 

Another way to look at this example is to say that the node 
15 represents the "intersection" of the concepts of piano player and 

Australia - it is where the two ideas come together within the 

directory. 

Extending this example, consider a node that is about "Piano 
Players in Australia and New Zealand" . In this case the meanings 

20 Australia and New Zealand might both be placed on the node, but 
grouped together in one "synset group", because the combination 
of the two describes the node's location within the "geographical 
location" dimension of meaning. Another way to look at this 
example would be to say that the node is about the intersection 

25 of the concept of piano player with the union of the concepts 
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Australia and New Zealand. The purpose of this synset grouping is 
solely to provide more accurate positioning of the node within 
semantic space, and a more accurate reflection of the specificity 
of the node, both of which result in improved search engine 
5 retrieval . 

The lexicon is updated and further developed primarily when 
ascribing nodes to a location in semantic space is impossible 
because the needed meaning does not exist in the semantic space. 
Thus, blocks 110 and 115 can be thought of as implemented in 
10 complementary fashion to one another. 

Block 120 

If the semantic space laid out by the lexicon developed as 
described with respect to block 110 is to be effectively used, 
the concept of "distance" from one meaning to another within this 

15 space must be defined. The input to this portion of the process 
is the lexicon Itself and the output is a table of information 
that details the distance from each meaning to each other meaning 
that falls within a certain "radius of semantic closeness". 

The closeness of meanings is affected to a large degree by 

20 their perceived "precision". For example, we can guess at how 
close the concepts of "sports" and "baseball" are based on the 
fact that there are many other particular kinds of sports under 
"sports" than baseball. As baseball appears to be one of many, 
it's connection to the concept of "sports" is not as strong as 

25 if, say, there were only two sports in the world, and baseball 
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was thus one of only two possibilities for what is meant by 
"sports''. This idea is reflected in an algorithm that estimates 
the " kind of" and "part of" precision of a meaning based on the 
total count of its descendants, following "kind of" and "part of" 
5 relationships. In these calculations, meanings marked as 

"instances" are biased against, as they would tend to incorrectly 
dilute the precision of a concept otherwise. 

Differences in estimates of precision are used to generate a 
semantic distance between two directly connected meanings only 
10 when a connection strength has not been set. Manual settings 
override the calculated estimates; thus the semantic distance 
results come about from a combination of automatically estimated 
connection strengths, and strengths that have been manually set. 
The process for discovering meanings that are semantically 
15 close to a specific meaning involves a traditional breadth- first 
search outward from the origin meaning. Neighboring meanings in 
the network of nodes are explored in an outward seeking fashion, 
and distance from the origin is tracked. When a certain radius 
has been reached, the search stops. Intricacies in this search 
20 include the following: 

1. A "scaling factor", somewhat like a "velocity" is tracked as 
the search spreads outward. This scaling factor multiplies the 
perceived distance for a single jump. One net effect of this 
factor is to reduce the perceived distance to meanings that 
25 are close, thus the drop-off of distance is not linear as the 
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search expands. This is a result of an increase in scaling 
factor based linearly on the previous jump distance. 
2. The scaling factor is also modified by a change in direction 
of the search within the lexicon hierarchy. For example, a 
5 jump down to a child from a parent that was previously jumped 
up to from another child, incurs a scale factor increase 
penalty. Similar penalties arise from jumps down then up, from 
jumps in "kind of" that occur after "part of" (and vice 
versa), and from combinations of these. 

10 3. Lateral "bond" type connections also incur scale factor 
penalties, based on the set distance of the jump. 
4. "Psuedosynset" and "instance" meanings are treated in a 
special way. When used as the origin, they imply that the 
search for related meanings should be within a smaller radius, 

15 as their own greater degree of exactness imply a more specific 
kind of search for meanings is called for. Thus the search 
does not expand as far; this is controlled by starting the 
search with a higher scaling factor. Additionally, a different 
measurement of precision is used, which includes detailed 

20 terms that are otherwise excluded from the standard precision 
algorithm initially. (Alternately, if the origin meaning is 
not a pseudo-synset or instance meaning, then the standard 
precision values excluding count of descendant pseudosynsets 
are used.) 

25 
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Block 130 

Once distances between meanings within the Lexicon have been 
determined, and target nodes within the directory have been given 
5 fixed positions within the semantic space described by the 
Lexicon, it is possible to generate scores for all nodes that 
fall close to each individual meaning. Pre-calculating these 
scores ahead of time allows a much quicker response time to 
actual searches. The inputs to this process are the lexicon, the 

10 table of relatives of each meaning, showing semantic distances, 
and the data that details what meanings have been attached to 
what nodes. The output of this process is information describing 
what nodes are close to each given meaning, and a "score" for 
that closeness, which is a direct reflection of the semantic 

15 distance from the origin meaning to the meanings that have been 
attached to the node. Other factors that affect the pre- 
calculated node scores for a meaning are the number of meanings 
attached to the node, and the "commonness" value of the meaning 
in question. 

20 An additional element of this pre-calculation step involves 

the creation of tables of information that allow very fast 
comparison between meaning when determining which nodes are hit 
by multiple meanings simultaneously. For this, bitmapped 
information that reflects a compressed version of the node- 

25 meaning score information is generated. Essentially, if a 

meaning has any score whatsoever for a particular node, a single 
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bit is set to 1 in a binary field, marking that node as hit. By- 
comparing the "bitmaps" for two meanings against each other, a 
quick assessment of "combination hits" can be made-it is simply a 
process of performing a bitwise AND operation on the two bitmaps. 
5 Because an uncompressed bitmap for every meaning would be an 

unmanageably large amount of data, which would also require a lot 
of processing time to analyze, the bitmap data is compressed. 
There are two levels of compression, each a level 8 times more 
condensed than the last. In the first level of compression, a 
10 single bit represents a set of 8 nodes. If a meaning has a score 
for any of these nodes, the bit is set. In the second level of 
compression, each bit corresponds to a set of 64 nodes, in the 
same way. 

Storing the bitmap information in this way allows large 
15 chunks of empty raw bitmap data to be ignored, resulting in a 
much smaller data set. In addition, the bitwise operations 
performed on these bitmaps can be done with greater speed, 
because detailed sections of the bitmap data do not have to be 
examined unless the higher- order compressed version indicates 
20 that there is information of value present there. 
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RETRIEVAL 

Block 140 

While pre-processing and information organization may be an on- 
going process, at anytime where at least a partial table of 
5 scores for nodes is available, the user can then input a specific 
search term as he/she would when using the conventional search 
engine . 

When users use the search engine to find subjects within the 
directory, the search engine conducts two phases of processing. 

10 The first phase, interpretation, involves analyzing the user's 
input so that the meanings that the user desires can be 
identified (see block 150 description) . The second phase, 
collection and ranking of results, involves the collecting of 
nodes that have good scores for the desired meanings, and 

15 ordering them based on predicted relevance (see block 160 
description) . 

Block 150: Interpretation Phase 

There are two key inputs possible for a search: an input 
string, and a set of known meanings. Either, or both, may be 
20 received and processed for results. The input string is simply a 
set of words that the user types into a search box and submits 
for query. An interpretation of these words is made, to map words 
to probable desired meanings. In addition to, or instead of, the 
input string, a set of meanings that are known ahead of time to 
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be of interest, may be passed to the. search enginei for query. 
These require less processing, as plain words to not have to be 
mapped to meanings, as they are already predefined. Meanings 
passed to the engine in this way are called preconceptions. 
5 The process for interpreting the input string begins with 

stemming, or morphing, of the individual words in the string. 
This involves mainly an attempt to reduce words perceived as 
being plurals to their singular form. This is necessary because 
word mappings to meanings within the Lexicon are stored in 

10 singular form only, except in special cases. 

Next, all possible combinations of words (and their morphed 
variants) are examined for possible matches to meanings. Larger 
numbers of combined words are tested first, to give preference 
over individual words (for example, " United States'' must take 

15 precedence over analysis of "United" and "States"). Partial 

matches with meanings are possible, so that "Rocky Horror" might 
bring up a match for "Rocky Horror Picture Show", for example. 

As the set of possible meanings is being compiled, 
probabilities are assigned to each. These values reflect the 

20 likelihood that the user really means a certain concept. Because 
many words have multiple meanings, probabilities for implied 
meanings for words may be manually or automatically pre -assigned. 
These values are used in this phase of the engine processing, in 
order to estimate what meanings are most likely implied by 

25 particular search words. Other factors that affect the 
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probabilities given to meanings are: was the meaning matched by a 
morphed word or the word in its "pure" form (favor pure forms); 
was the meaning only partially matched the input word(s) (if so, 
reduce probability); was the meaning the result of a match on 
5 multiple words (if so, increase probability) ; the commonness of 
the meaning implied (favor more common meanings) . 

Another kind of "concept induction" is applied to the 
analysis at this point. All implied meanings are examined and 
compared against each other, so that relationships might be 

10 discovered. If there is a connection between two meanings, those 
meanings will receive a bonus to their probability factor, 
because the implication is that those particular meanings of the 
user's words were what the user wanted. (These comparisons 
actually occur between the all the meanings that are 

15 possibilities for one search word against all those for each 

other search word). Thus if the user enters "Turkey Poultry" , the 
meaning of "turkey" as a kind of food will receive a bonus, 
because a connection between a meaning deriving from "poultry" 
relates to this particular meaning of "turkey" . This is extremely 

20 valuable in tuning meaning probabilities, because without this 
weighting, for example, the meaning "Turkey, the country" might 
have been preferred. 

Lastly, a set of simple plain words is compiled, based on 
the raw input terms, and given weighting factors based on whether 

25 or not meanings were implied by those terms. These plain words 
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are used for a more standard word-matching search, that is 
conducted concurrently with the meaning-based search. Weighted by 
a lesser degree than meaning-based results, hits on subject nodes 
based on these plain words do play a factor in the scoring of 
5 nodes in the second phase of the search. 

Processing of preconceptions in the Interpretation phase is 
simpler, as the meanings that the user desires are passed as 
direct input to the engine. The only processing that is necessary 

10 is a weighting on the importance of these meanings, which is 

applied by analyzing the commonness of the meanings in question. 

One additional factor remains to be mentioned in the 
Interpretation phase. Certain meanings may be considered as 
"required" in the search results. Users can specify they want to 

15 require certain meanings to show up in the results by putting a 
plus sign ( + ) before the appropriate word or phrase in the input 
string. Additionally, preconceptions may or may not be sent to 
the engine as * required" meanings. By default, the engine 
performs a logical OR operation on all input meanings. When 

20 meanings are " required" , it implies that a logical AND should be 
performed on these terms. 

Block 160: Collection and Ranking Phase 

Once the meanings of interest to the user have been 
25 determined in the Interpretation phase, and given appropriate 
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weightings based on the likelihood of value, actual nodes that 
relate to these meanings can be collected and ordered for 
presentation. 

This phase begins with the collection of bitmap information on 
5 the desired meanings. Only meanings . that have more than a set number 
of node scores have bitmap information, these meanings are called 
popular. (Exception: if the search is being performed for a single 
input word, these bitmaps do not have to be collected.) Discovering 
bitmap information stored for meanings indicates to the engine their 
10 popular state. 

Next, the "top scoring nodes" for all meanings are queried from 
the pre-calculated score information. Meanings that were not found to 
be popular have their bitmaps constructed during this stage, as all of 
their scored nodes will be present in this "top scoring" category. 

15 Unless the search is to be a special AND operation between terms, we 
begin to compile a list of potential node results from these score 
table queries. (If the search is a pure OR, these results are likely 
to be useful. If an AND is to be done, the chances are good that most 
of these results will be filtered out, therefore all node scoring is 

20 performed later in this case.) 

The bitmap analysis phase comes next. Behavior of the engine here 
varies widely between cases where different kinds of terms are 
required/not required. In general, the point of bitmap analysis is for 
either of the following reasons, or for a combination of them: 

25 • Find out what nodes are hit by more than one meaning, because they 
are likely to yield very good scores due to the combination hit 
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factor. Many of these nodes will not have shown up in the 
individual meanings' "top scoring nodes" lists, and therefore would 
have been missed had we not looked specifically for combinations. 
• Filter out only nodes that show up on required meanings, because a 
5 logical AND between terms is being performed. 

Bitmap processing involves a series of bitwise OR and AND 
operations, which occur in two passes. Processing is done first on the 
highest level of compression, to get a rough idea of what areas of the 

10 bitmaps need to be examined in more detail. Next the detailed bitmap 
information of interest is queried from the database. Finally, the 
logical processing is run again at the uncompressed level of detail. 

The result of the bitmap processing is a set of nodes of 
interest. These nodes are queried from the score tables for all 

15 meanings of interest and added to the list of potential results nodes. 
The next stage is actual scoring of node results. Node scores 
result primarily from a multiplication of the score for the node for a 
given meaning and the probability factor for that meaning that came 
out of the Interpretation phase. Additional bonuses are given to nodes 

20 that are hit by a combination of meanings. The "portion of meaning" of 
the node is also considered. For example, if a node has three attached 
meaning groups (synset groups) , and two of those meanings were queried 
by the user, we can say roughly that 2/3 of the concept behind this 
node was of interest to the user. Thus this node is probably of less 

25 interest to the user than one whose concept was hit more completely. 

Other special considerations are also introduced, such as the favoring 
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of nodes that are hit " perfect 1/' by meanings, over those that were 

separated at all by some distance in semantic space. 

It should also be mentioned here that some additional tricky 

processing comes into play when dealing with the simple plain word 
5 hits, whose processing is concurrent to the meaning-based search 

processing that this paper focuses on. Special processing for plain 

words is performed that involves searching for matches of different 

plain word search terms on the same sentences on the subject node 

pages that are to be pulled up as results. Additionally, different 
10 weighting comes into play based on where plain words appear - for 

example, a word showing up in the title of a node is valued more than 

the appearance of that word later on the page. 

After scoring, all that is left in anticipation of results 

presentation is a sorting of the node results by score, the selecting 
15 out of those nodes whose scores merit presentation, and the 

classification of these nodes into groups of "strong", "medium", and 

"weak" score values. 

Block 170 

As mentioned above, users interact with the search engine 
20 directly by entering an input string into a simple input box on a Web 
page. In a standard initial query, whose span is the entire directory, 
this string is passed to the engine for interpretation without any 
preconceptions as parameters. Results spanning all subjects in the 
system are retrieved and presented to the user so they may 
25 subsequently navigate to those areas of the directory. 
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Once the user is on a particular subject page of the directory, 
however, they also have the option to perform a narrow search. 
Essentially, this is a search for subject matter that is "close in 
meaning" to the subject page they are currently on. These kinds of 
5 searches are performed by the passing of the meanings attached to the 
given subject to the search engine as preconceptions, along with the 
user's input string. In this case, the preconceptions are designated 
as required, and the input string terms, as a whole, are also treated 
as required terms. 

10 Whenever a user performs a search, the node results are preceded 

by a description of what meanings were actual searched on. Because 
these meanings are often the result of the interpretation of the 
user's input string, and may include multiple possible meanings for 
given words, the user is encouraged here to specify exactly what 

15 meanings they wanted, and to search again. This second search is 

called a refined search. Essentially, the user is presented with a set 
of checkboxes, each of which corresponds to a possible intended 
meaning. The user refines the search by simply checking off the 
meanings she wishes to search on, and clicking on "Search Again". 

20 A refined search is passed to the search engine as a set of non- 

required preconceptions, thus an OR operation is performed on all of 
the meanings. Increased functionality in this part of the system, 
including the option to set specific meanings as "required", as well 
as the ability to include plain word searching in refined searches, is 

25 planned for the near future. 
Block 180 
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• 



Node results, i.e. target documents, having the desired meaning 
or closeness in meaning to the concept searched for may then shown to 
the user. The user in turn may navigate the nodes presented him or 
refine his search in accordance with block 170 described above. Once 
5 nodes are collected and ranked in accordance with block 160 (also 

described above) , then they may shown to the user as results with the 
highest ranked nodes appearing first. This concludes the retrieval 
stage where the user has now successfully navigated to the site of 
interest. As compared with conventional Web search engines and 
10 directories, searching in a meaning-based fashioned as described above 
allows users to more quickly locate relevant and useful documents or 
sites. 

Figure 2 illustrates a portion of a relationship based lexicon 
employed in one or more embodiments of the invention. 

15 Figure 2 shows one portion of a sample lexicon 200 which differs 

from conventional lexicons by adding a lateral bond ("bind") 
connection between elements. The boxed elements in Figure 2 represent 
meanings within the lexicon and collectively, along with the 
relationship connections between meanings can be viewed as defining a 

20 semantic space. The three basic relationship types "part of", "kind 
of" and "bind" are represented by differing line types in Figure 2, a 
legend for which is drawn thereon. 

The relationships between elements may take on many forms and can 
become quite complex, but for ease of illustration, a simple is shown 

25 in Figure 2 dealing with skiing. 

Starting with the branch for "sport", "skiing" is defined in the 
lexicon 200 as a kind of "sport". The word "ski" typically, in its 
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noun form, can be thought of as related to "skiing" in that it is a 
part of " skiing" as shown in Figure 2. "Slalom skiing" is a type of 
skiing and hence a kind of connection is shown between it and 
"skiing". "Bindings" are a structural attachment on a ski, and hence 



specific brand of ski, "K2 ski," is given to show how it is in a "kind 
of connection with "ski". 



also assigned a lateral bond showing a conceptual commonness with the 
manufacturer of the ski "K2" which lies in the "company" branch. The 



"K2" company. 

Considering ^ski" once again, "ski" is also a child of the 
"equipment" branch which has "athletic equipment" as a kind of 
"equipment" and ski as a kind of "athletic equipment". "Surfboard" is 
related to "ski" in that it too is a kind of "athletic equipment". 
Target documents or nodes within a subject directory may be "placed" 
or "located" by human intervention" into the semantic space as defined 
by lexicon 200. A website that sells skis or has information about 
skiing destinations would fall somewhere within the defined semantic 
space based upon its focus of content. 

Figure 3 illustrates the concept of bond strength and semantic 
distance in one or more embodiments of the invention. 

Using the same exemplary lexicon 200 of Figure 2, Figure 3 
illustrates how distance and closeness of meaning between meanings can 
be quantified within the semantic space. Distances are shown between 



it is assigned a part of connection with "ski". 



The example of a 



Unique to the lexicon developed for the invention, "K2 ski 



is 
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the element "ski" and all other elements within the semantic space. 
Using three classes of bond strengths the degree of closeness between 
meanings may be discovered. A " strong relationship" exists between 
"ski" and "skiing" as does between "ski" and "athletic equipment." 
5 Between "skiing" and "sport" there is a weaker than strong 

relationship known as a "medium relationship" . This is because when 
you think of the root term "skiing" one doesn't quickly think also of 
"sport". Going from "ski" to "skiing" however, the average person 
would more likely associate or think "skiing" if given the term "ski". 

10 The direction in the arrows in the bond strengths, indicates the 

direction of association. "A — > B" in Figure 3 means that if you are 
given A, how likely is it or closely would one associate the meaning 
B. Going the other direction between the same two elements may 
produce a different bond strength. A "weak relationship" would be 

15 displayed between "ski" and "K2 ski" (when you think of "ski," "K2 
ski" doesn't closely come to mind). However, if one were to go from 
"K2 ski" to "ski" this might be construed as a strong relationship 
since one would naturally associate "ski" if given "K2 ski". 

Figure 3 also shows semantic distances between elements. "Ski" 

20 and "skiing" have only a distance of 2 between them while "skiing" and 
"sport" have a distance of 5 (7-2). The distance between "ski" and 
"sport" is 7. When travelling from parent to child or vice-versa, the 
distances can be simply added/subtracted but when changing the 
direction of travel, a penalty may be imposed upon the distance 

25 calculation. Take for example the distance between "ski" and 

"athletic equipment company". Judging merely on a linear basis, the 
distance might be 12. But since the path from "ski" to "athletic 
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equipment" switches direction twice (it starts down to "K2 ski" and 
then across the lateral bond to "K2" and then up to "athletic 
equipment company") a penalty or scaling factor would cause the 
distance between "ski" and "athletic equipment" to be much larger than 



5 just 12 especially given their lack of connectedness. As described 



above penalties may be added when the direction of traversal is 
switched or when a lateral bond is crossed. Meaning-by-meaning, 
distances between elements may be calculated and stored for future use 
in search retrieval. 



Given a lexicon 400 (similar to lexicon 200) and a subject 
directory 410, Figure 4 illustrates how "Skiing in California" may be 
assigned a location in the semantic space. In the subject directory 

15 410, the subject Sports has associated with it the child subjects of 
"Football", "Skiing" "Baseball" and "Tennis." The subject "Skiing" 
has its own children "Skiing in California", "Skiing in Colorado" 
"Skiing in Alaska" and "Skiing in Washington". In the semantic space 
"Skiing in California" would be assigned to "skiing" as well as to 

20 "California". The node "Skiing in California" would thus be ascribed 
the element "skiing" as well as "California" such that both meanings 
and related meanings would be available as additional refinements. 
For instance, consider "Los Angeles", a city in California. If 
another node of directory 410 described "Things to do in Los Angeles", 

25 by virtue of the connectedness of "Los Angeles" as part of 

"California" within the semantic space, this node may also be 



10 



Figure 4 illustrates the application of synsets to 
categories in a subject directory tree. 
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presented to the user when a search. for "Calif ornia" or "skiing in 
California" is performed even though none of the literal sub-strings 
match with the node. The meanings or closeness in concept would bring 
such relevancy of nodes to the forefront. 

5 Figure 5 is a system diagram of one embodiment of the 

invention. Illustrated is a computer system 510, which may be 
any general or special purpose computing or data processing 
machine such as a PC (personal computer), coupled to a network 
500. 

10 One of ordinary skill in the art may program computer system 

510 to act as a meaning-based search engine. This may be 
achieved using a processor 512 such as the Pentium® processor (a 
product of Intel Corporation) and a memory 511, such as RAM, 
which is used to store/load instructions, addresses and result 

15 data as needed. The application (s) used to perform the functions 
of a meaning-based information organization and retrieval system 
may derive from an executable compiled from source code written 
in a language such as C++. The instructions of that executable 
file, which correspond with instructions necessary to scale the 

20 image, may be stored to a disk 518, such as a floppy drive, hard 
drive or CD-ROM 517, or memory 511. The lexicon, directory and 
scoring and distance tables and other such information may be 
written to/accessed from disk 518 or similar device. The 
software may be loaded into memory 511 and its instructions 

25 executed by processor 512 . 
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Computer system 510 has a system bus 513 Which facilitates 
information transfer to/from the processor 512 and memory 511 and 
a bridge 514 which couples to an I/O bus 515. I/O bus 515 
connects various I/O devices such as a network interface card 
5 (NIC) 516, disk 518 and CD-ROM 517 to the system memory 511 and 
processor 512. The NIC 516 allows the meaning-based search 
engine software executing within computer system 510 to transact 
data, such as queries from a user, results of such queries back 
to users that present meaning-based results and refinements to 
10 searches performed, with users connected to network 500. Filters 
and other meaning-based search utilities may be distributed 
across network 500. 

Many such combinations of I/O devices, buses and bridges can 
be utilized with the invention and the combination shown is 
15 merely illustrative of one such possible combination. 

Figure 6 is a flowchart of meaning-based advertising 
according to one or more embodiments of the invention. 

Meaning-based advertising may be achieved by placing or 
indexing ads within the semantic space. As with documents 

20 indexed into semantic space, advertisements may be indexed or 
placed within the semantic space according to their targeted 
meaning. For instance, an advertisement from a desktop and 
laptop computer retailer might be indexed at/near a synset for 
personal computer. This places the advertisement into semantic 

25 space such that it would be retrieved according to an input that 
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has a semantic "sub-space" that includes the advertisement's 
location. An advertisement such as an internet banner ad can 
thus be accessed or retrieved not merely by a keyword or 
category, but rather by a semantic concept that may encompass 
5 many words, equivalent words and words of related meaning. 

For instance, the computer retailer in the above example 
would be able to place the ad into the synset corresponding to 
personal computers. By doing so, a search engine or mechanism 
that utilizes this semantic space may sell the concept of 

10 "personal computer" to the advertiser. Instead of a keyword or 
even multiple keywords the purchase of a concept such as 
* personal computer" may be much more valuable to the advertiser 
and the potential viewer of the ad. Input words such as "PC", 
"laptop" "desktop" and "workstation" would be related closely 

15 with one another and thus fall in close proximity to one another. 
As a result, an input of any of these words to a search engine or 
filter would result in retrieval of the same banner ad. Further, 
depending on the radius of semantic distance used to define the 
sub-space from the synset "personal computer" , many other less 

20 closely associated words (meanings) may also trigger retrieval of 
the same advertisement. For instance, the word "hardware" in one 
of its meanings indicates devices that are used in a computing or 
communications environment. While "hardware" is not equivalent 
to "personal computer/' within a semantic space, "personal 

25 computer" may be related to the synset for "hardware" as a type 
of "hardware" and fall close enough in semantic distance such 
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that an input of hardware might retrieve the same advertisement 
as would an input of "personal computer" . This procedure, as it 
relates to a searching utility or engine is described below. 

First, a user enters a search term (block 610). This search 
5 term is then fed to the search engine or filter that 

differentiates based on semantic relationships (meanings) in a 
lexicon (block 620) . One example of a semantic engine is the 
meaning-based differentiator described above. A meaning-based 
search engine then determines the sub-space in the whole semantic 

10 space that encompasses the search term. The semantic sub-space 
is determined by first fixing a point in semantic' space closest 
to or at the synset (meaning) that best suits the search term. 
After fixing this point in the entire semantic space, all 
elements of the semantic space within a certain radius of 

15 semantic distance will comprise the semantic "sub-space" 

governing the term that was searched (block 630) . Once the 
semantic sub-space has been determined, then ad banners 
positioned within the sub- space can be found (block 640) . This 
assumes that prior to the search banner ads have been indexed 

20 into semantic space. 

If there are no banner ads within the semantic sub-space 
(checked at block 645), then the radius of semantic distance can 
be increased (block 647) or by other means, the semantic sub- 
space can be expanded upon until banner ads are found. Once 
25 banner ads are found within the original or expanded semantic 
sub-space these ads may be displayed (block 650) . If there is 
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more than one banner ad within the semantic sub-space and only 
one ad is to be displayed then the ad positioned closest in 
semantic distance (most closely associated) to the search term 
can be displayed. In an alternate embodiment, if no documents 
5 are found within the original semantic sub-space, it may be 

desirable to retrieve no ads. Also, where the semantic sub-space 
is expanded, it may be desirable to terminate the process of 
expanding the sub- space beyond a certain threshold since the 
likelihood of a relevant ad may decrease with such an expansion. 

10 In accordance with the operation of a semantic or meaning 

based search, the user may be able to select a given meaning from 
a set of possible meanings (block 660) . If the user selects a 
particular meaning or word context, then the semantic sub-space 
is redefined (block 670) and new banner ads can be found (block 

15 640) . While Figure 6 and other embodiments refer to 

advertisements or banner ads, these principles can be applied to 
retrieval of any documents, images, sounds or other data, and is 
provided as one example finding documents based on their semantic 
content or purpose. 

20 Figure 7 illustrates advertisements indexed within a 

semantic space. 

The semantic space 700 of Figure 7 includes six nodes or 
synsets A, B, C, D, E and F. The semantic space 700 is 
illustrated for convenience as a two dimensional space with 
25 connections between various nodes showing their inter- 
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relationship. An actual semantic space may be thought of as 
having N-dimensions, given the complex possible associations 
between synsets, words, subjects and meanings. In general, the 
further away one location in the space from another, the less 
5 related or associated semantically are the nodes. There are two 
advertisements, Advertisement 1 and Advertisement 2 indexed 
within the shown semantic sub-space at various locations. This 
positioning of documents such as advertisements may be made 
manually or by some automated process. 

10 Several semantic sub- spaces are also shown. These sub- 

spaces are triggered by an input of a term or meaning that 
equates to a synset. A user or mechanism inputting a term that 
is associated with the node D will generate a semantic sub-space 
710. With sub-space 710 thus defined, an ad, Advertisement 1 is 

15 found immediately. Semantic sub-space 710 is a "first" semantic 
sub-space which is an initial guess at a given semantic radius 
about the node D. In this case, an advertisement was discovered 
contained therein without any expansions of the space. 
Consequently, taking the example of a search engine portal 

20 website, a user visiting that website that enters a term 

equivalent to the node D would trigger retrieval of Advertisement 

By contrast, a first semantic sub-space 720, determined by 
an input term associated with node F, contains no advertisements 
25 to retrieve. As a consequence, in one embodiment, the semantic 
radius about the node F may be increased until an ad is found. 
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In this instance, the semantic radius about node F was increased 
to give an expanded sub-space 730. The semantic sub-space 730 
contains Advertisement 2. Thus, subject to an expansion from the 
first semantic sub-space 720, a user entering in a search term 
5 associated with node F will retrieve Advertisement 2. Unlike 
traditional keyword advertising, input of related meanings may 
also retrieve the same Advertisement 2. For instance, an input 
term associated with node C would likely also retrieve 
Advertisement 2, since both node C and F are related or connected 
10 concepts. 

Figure 8 is a flowchart of keyword generation by semantic 
filtering. 

Where a particular web site or other information portal 
desires to sell keywords to an advertiser as is the traditional 

15 practice, both the advertiser and the portal may not know all of 
the right keywords. Utilizing the semantic space and lexicon of 
meanings, an entire list of keywords can be generated when 
starting from a particular term or set of terms that matches even 
roughly the desired theme. For instance, if trying to find 

20 keywords intended for a candy advertisement, then a starting 
input of " candy" might return a semantic sub-space containing 
with related and associated words such as * sweets/' "chocolate," 
"licorice," and "toffee". Such keyword or related word 
generation based upon a semantic lexicon can be applied to other 

25 information applications such as word processing and artificial 
intelligence or the indexing of documents and data. The 
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generation of keywords and related words based upon semantic 
principles is discussed below. 

First, by some mechanism, an input term or phrase is fed to 
the semantic engine (block 810) . In the case of advertising, the 
5 advertiser or portal can enter in the input term(s) . For other 
applications, the input may be fed automatically from another 
document or data source. Using the input search, the semantic 
engine determines a semantic sub- space encompassing the meaning 
of the input term (block 820) . As with the semantic search 

10 engine described above, the keyword generation may be refined 
based upon the selection of a particular meaning of the input 
term(s) where the input terms have more than one possible meaning 
(checked at 815) . If the meaning is refined (block 815) the 
refined term (meaning) is fed back to the semantic engine (block 

15 810) . If there are no more refinements to be made, then a new 
semantic sub-space is determined (block 820) . With the semantic 
sub- space determined, the keywords, related words and meanings 
that belong to the sub-space can all be retrieved (block 830) . 
This list of related words and meanings can then be displayed to 

2 0 a user. 

Figure 9 is a graph of meaning-based advertising pricing 
according to another embodiment of the invention. 

With the aid of semantic space, an advertising campaign may 
be sold on a variable rather than a fixed cost basis. The cost 
25 of the banner ad or other ad when retrieved can be based directly 
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upon the semantic distance (i.e. degree of closeness in 
meaning/context) from a key term that was purchased to the input 
term(s) . For instance, if the purchased synset by a candy 
website for its ad is "candy" and a search term "snack foods" is 
5 entered as input, this may still trigger retrieval of the candy 
website ad (due to a semantic proximity) . However, since this 
user was probably not as interested in a candy website, the ad 
may not be reaching the as valuable a target user as one who may 
have entered "candy" as a search term. Even though the ad was 
10 retrieved, its display may not be that valuable to the 

advertiser. In most Internet advertising pricing models, 
advertisers buy "page views" (the number of times their ad is 
displayed) without any regard to the relevance of the ad to the 
user and correspondingly, the effectiveness to the advertiser. 

15 Using semantic space, the relevance of the ad to the user 

can be determined based upon the input terms. The price of that 
particular page view can be modified based upon the semantic 
distance between location in semantic space of the purchased 
synset and the input term(s) . One way to formulate this relation 

20 is to say that the semantic distance is inversely proportional to 
the price of the ad. The farther away in semantic space the 
input term is to the purchased synset, the less the ad will cost 
the advertiser. Conversely, the closer in semantic space the 
term is to the purchased synset, the more the ad will cost the 

25 advertiser. This relationship is demonstrated in the graph of 
Figure 9 which plots semantic distance against the price of the 
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ad to the advertiser. The graph of Figure 9 and the inverse 
relation described above is one of many possible formulations of 
variable pricing according to semantic relationship and is merely 
illustrative. Other factors may include the path through 
5 semantic space, the type of semantic relationship between the 
term and purchased synset and the presence of other ads within 
the same semantic sub-space. 

The exemplary embodiments described herein are provided 
merely to illustrate the principles of the invention and should 
10 not be construed as limiting the scope of the invention. Rather, 
the principles of the invention may be applied to a wide range of 
systems to achieve the advantages described herein and to achieve 
other advantages or to satisfy other objectives as well. 
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